package com.suanfa.collect;

import com.alibaba.fastjson.JSON;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/**
 * 数组3个元素相加=0，获取所有组合
 */
public class ThreeSumZero {

    public static void main(String[] args) {
        int[] arr = {-1, 0, 1, 2, -1, -4};
        ArrayList<ArrayList<Integer>> result = getResult(arr);
        System.out.println(JSON.toJSONString(result));
    }


    public static ArrayList<ArrayList<Integer>> getResult(int[] arr) {
        ArrayList<ArrayList<Integer>> result = new ArrayList<>();
        if (arr.length < 3) {
            return result;
        }
        Arrays.sort(arr);

        for (int i = 0; i < arr.length; i++) {
            int value = arr[i];
            //不再有符号位条件的数据
            if (arr[i] > 0) {
                break;
            }
            //重复的不再处理
            if (i > 0 && arr[i] == arr[i - 1]) {
                continue;
            }

            int l = i + 1;
            int r = arr.length - 1;

            while (l < r) {
                int sum = arr[i] + arr[l] + arr[r];

                if (sum == 0) {
                    ArrayList<Integer> list = new ArrayList<>();
                    list.add(arr[i]);
                    list.add(arr[l]);
                    list.add(arr[r]);
                    result.add(list);
                    while (l < r && arr[l] == arr[l + 1]) {
                        l++;
                    }
                    while (l < r && arr[r] == arr[r - 1]) {
                        r--;
                    }
                    l++;
                    r--;
                } else if (sum < 0) {
                    l++;
                } else {
                    r--;
                }


            }


        }


        return result;
    }
}
